Skip to content

Conversation

@kunhwiko
Copy link

@kunhwiko kunhwiko commented Oct 3, 2025

Issue #, if available:
N/A

Description of changes:
updateComputeConfig seems to currently be susceptible to NPE errors, especially when the user isn't using EKS Auto Mode.

The function is executed when any one of these conditions are met:

  • delta.DifferentAt("Spec.ComputeConfig")
  • delta.DifferentAt("Spec.StorageConfig")
  • delta.DifferentAt("Spec.KubernetesNetworkConfig")

There is no guarantee that all 3 fields are fully populated, so we may need to gracefully handle some inputs.

By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.

@ack-prow ack-prow bot added the do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. label Oct 3, 2025
@ack-prow
Copy link

ack-prow bot commented Oct 3, 2025

[APPROVALNOTIFIER] This PR is NOT APPROVED

This pull-request has been approved by: kunhwiko
Once this PR has been reviewed and has the lgtm label, please assign jlbutler for approval by writing /assign @jlbutler in a comment. For more information see the Kubernetes Code Review Process.

The full list of commands accepted by this bot can be found here.

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@ack-prow ack-prow bot requested review from a-hilaly and jlbutler October 3, 2025 22:54
@ack-prow ack-prow bot added the needs-ok-to-test Indicates a PR that requires an org member to verify it is safe to test. label Oct 3, 2025
@ack-prow
Copy link

ack-prow bot commented Oct 3, 2025

Hi @kunhwiko. Thanks for your PR.

I'm waiting for a aws-controllers-k8s member to verify that this patch is reasonable to test. If it is, they should reply with /ok-to-test on its own line. Until that is done, I will not automatically test new commits in this PR, but the usual testing commands by org members will still work. Regular contributors should join the org to skip this step.

Once the patch is verified, the new status will be reflected by the ok-to-test label.

I understand the commands that are listed here.

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository.

defer exit(err)

// Convert []*string to []string for NodePools
nodePools := make([]string, 0, len(r.ko.Spec.ComputeConfig.NodePools))
Copy link
Author

@kunhwiko kunhwiko Oct 3, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So updateComputeConfig seems to be triggered when one of these conditions are met:

  • delta.DifferentAt("Spec.ComputeConfig")
  • delta.DifferentAt("Spec.StorageConfig")
  • delta.DifferentAt("Spec.KubernetesNetworkConfig")

As an example here, users that aren't using EKS auto mode might be using Spec.KubernetesNetworkConfig but are likely to leave Spec.ComputeConfig and Spec.StorageConfig empty. This leads to a NilPointerException.

@kunhwiko kunhwiko force-pushed the khk-npe-update-compute-config branch from 11028df to b19ab8f Compare October 3, 2025 23:00
@kunhwiko kunhwiko marked this pull request as ready for review October 3, 2025 23:05
@ack-prow ack-prow bot removed the do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. label Oct 3, 2025
@ack-prow ack-prow bot requested a review from michaelhtm October 3, 2025 23:05
@kunhwiko kunhwiko force-pushed the khk-npe-update-compute-config branch 3 times, most recently from dcfd48a to f8c7d61 Compare October 5, 2025 06:38
@a-hilaly
Copy link
Member

a-hilaly commented Oct 5, 2025

/ok-to-test

@ack-prow ack-prow bot added ok-to-test Indicates a non-member PR verified by an org member that is safe to test. and removed needs-ok-to-test Indicates a PR that requires an org member to verify it is safe to test. labels Oct 5, 2025
@kunhwiko kunhwiko force-pushed the khk-npe-update-compute-config branch from f8c7d61 to f433496 Compare October 5, 2025 07:33
@kunhwiko kunhwiko force-pushed the khk-npe-update-compute-config branch from f433496 to de98d00 Compare October 5, 2025 08:10
Comment on lines 9 to 17
latestConfig := ko.Spec.KubernetesNetworkConfig

// ElasticLoadBalancing can by default be initialized as false even when ACK is providing an empty input.
// This condition prevents unnecessary deltas when the desired value is empty and ElasticLoadBalancing is already disabled.
if latestConfig != nil && latestConfig.ElasticLoadBalancing != nil && latestConfig.ElasticLoadBalancing.Enabled != nil {
if *latestConfig.ElasticLoadBalancing.Enabled == false && r.ko.Spec.KubernetesNetworkConfig.ElasticLoadBalancing == nil {
latestConfig.ElasticLoadBalancing = nil
}
}
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

One thing that I noticed is even with an empty elasticloadbalancing input:

spec:
  accessConfig:
    authenticationMode: CONFIG_MAP
  kubernetesNetworkConfig:
    ipFamily: ipv4
    serviceIPv4CIDR: 172.20.0.0/14

The AWS API sometimes is returning this field initialized with some default:

aws eks describe-cluster --name <cluster-name>

"kubernetesNetworkConfig": {
    "serviceIpv4Cidr": "172.20.0.0/14",
    "ipFamily": "ipv4",
    "elasticLoadBalancing": {
        "enabled": false
    }
},

This is causing a delta to always occur between desired (i.e. user input) / latest (i.e. fetched from AWS). Anyways either nil or false here should indicate we don't want EKS auto mode to be turned on.

Comment on lines 4 to 5
go_version: go1.24.0
version: v0.33.0-102-g3756200
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Something wrong with my local setup..?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You just need to pull the git tags

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@a-hilaly That did it :D Any tips for the go version as well?...

@kunhwiko
Copy link
Author

kunhwiko commented Oct 5, 2025

/test eks-kind-e2e

@kunhwiko kunhwiko force-pushed the khk-npe-update-compute-config branch from d7d3ecd to c648716 Compare October 6, 2025 19:15
@kunhwiko kunhwiko force-pushed the khk-npe-update-compute-config branch from 80bcdab to 6569a97 Compare October 7, 2025 18:36
@ack-prow
Copy link

ack-prow bot commented Oct 7, 2025

@kunhwiko: The following test failed, say /retest to rerun all failed tests or /retest-required to rerun all mandatory failed tests:

Test name Commit Details Required Rerun command
eks-verify-attribution 6569a97 link false /test eks-verify-attribution

Full PR test history. Your PR dashboard.

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository. I understand the commands that are listed here.

@rushmash91
Copy link
Member

Hi @kunhwiko ,

This was a reported issue, and I merged the changes for it. Missed this PR already existed.
Thank you for your contribution! The fix was merged.
/close

@ack-prow ack-prow bot closed this Oct 14, 2025
@ack-prow
Copy link

ack-prow bot commented Oct 14, 2025

@rushmash91: Closed this PR.

In response to this:

Hi @kunhwiko ,

This was a reported issue, and I merged the changes for it. Missed this PR already existed.
Thank you for your contribution! The fix was merged.
/close

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

ok-to-test Indicates a non-member PR verified by an org member that is safe to test.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants